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The present invention relates to apparatus and methods for decoding 
information that has heen embedded in information signals, such as audio, video or data 
signals. 

Watermarking of information signals is a technique for the transmission of 
additional data along with the information signal. For instance, watermarking techniques can 
be used to embed copyright and copy control information into audio signals. 

The main requirement of a watermarking scheme is that it is not observable 
(i.e. in the case of an audio signal, it is inaudible) whilst being robust to attacks to remove the 
watermark from the signal (e.g. removing the watermark will damage the signal). It will be 
appreciated that the robustness of a watermark will normally be a trade off against the quality 
of the signal in which the watermark is embedded. For instance, if a watermark is strongly 
embedded into an audio signal (and is thus difficult to remove) then it is likely that the 
quality of the audio signal will be reduced. 

Various types of audio watermarking schemes have been proposed, each with 
its own advantages and disadvantages. For instance, one type of audio watermarking scheme 
is to use temporal correlation techniques to embed the desired data (e.g. copyright 
information) into the audio signal. This technique is effectively an echo-hiding algorithm, in 
which the strength of echo is determined by solving a quadratic equation. The quadratic 
equation is generated by auto-correlation values at two positions: one at delay equal to t, and 
one at delay equal to 0. At the detector, the watermark is extracted by determining the ratio of 
the auto correlation function at the two delay positions. 



WO 00/00969 in the name of Aris Technologies describes a technique for 
embedding or encoding auxiliary signals into an information host or cover signal. A replica 
of the cover signal, or a portion of the cover signal in a particular domain (time, frequency or 
space), is generated according to a stego key, which specifies modification values to the 
parameters of the cover signal. The replica signal is then modified by an auxiliary signal 
corresponding to the information to be embedded, and inserted back into the cover signal so 
as to form the stego signal. 
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At the decoder, in order to extract the original auxiliary data, a replica of the 
stego signal is generated in the same manner as the replica of the original cover signal, and 
requires the use of the same stego key. The resulting replica is then correlated with the 
received stego signal, so as to extract the auxiliary signal. The extraction of the auxiliary 
5 signal is relatively complex, and requires the stego key at both the encoder (or embedder) and 
decoder (or detector). Additionally, a brute force search is required to synchronize to the 

auxiliary signal at the detector. 

Further, performance of the payload extraction is dependent on how well the 
auxiliary signal can be estimated. In a system with a high expected error rate of the payload 
"lO bits in the auxiliary signal, this is very difficult to achieve. Solutions would lead to very 
complex error correction methods, or significantly limit the information capacity. 

It is an object of the present invention to provide a compensation for time 
offset for a watermark decoding scheme that substantially addresses at least one of the 

1 5 problems of the prior art. 

In a first aspect, the present invention provides a method of compensating for 
offset in a received signal, the signal being modified by a sequence of symbols, each symbol 
extending over T. signal samples, the method comprising the steps of: (a) dividing the 
received signal into frames of predetermined length 7V,(b) dividing each frame into a plurality 
20 of N b sub-frames;(c) forming N b sequences of values, the values being derived from the 

corresponding sub-frame within each frame; and (d) taking said N b sequences as successive 
estimates of a frame sequence correctly aligned (with no offset) to the sequence of symbols. 
Preferably, each frame overlaps an adjacent frame. 
Preferably, each sub-frame overlaps an adjacent sub-frame. 
25 Preferably, N b lies within the range 2 to 8. 

Preferably, the sequence of symbols comprises Ly, symbols, the received signal 
being divided into L F frames, wherein L F is an integral multiple of T s -Ly,. 

Preferably, each symbol of the said sequence extends over T 3 samples. 
Preferably, said symbols are shaped with a window shaping function that has a 
30 band limited frequency behavior and, within the pass band, has a smooth (graceful) temporal 
behavior. Further, the window shaping function preferably has a symmetric or anti- 
symmetric temporal behavior. 

Preferably, said window shaping function is one of raised cosine functions or 

bi-phase functions. 
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Preferably, said offset is a time offset between the received and the transmitted 

signals. 

Preferably, the method further comprises processing each estimate generated 
in step (d) as though it was the correctly aligned frame sequence, so as to determine which 
estimate is the best estimate. 

The method preferably further comprises the step of correlating each of said 
estimates with a reference sequence corresponding to said sequence of symbols; and 
taking the estimate with the maximum correlation peak value as the best estimate. 

Preferably, the best estimate is assumed to be the first estimate that, when 
processed, exceeds one or more predetermined conditions. Preferably, the processing of 
estimates stops once a working estimate has been determined. 

Preferably, once a working estimate has been determined for a first signal or 
portion of a signal, the method is repeated for a further received signal or portion of a signal, 
the estimates from said further signal being processed in an order dependent upon said first 
best estimate. Thus the method can adaptively correct for offset. 

In a further aspect, the present invention provides a computer program 
arranged to perform the above method. 

In another aspect, the present invention provides a record carrier comprising 
the above computer program. 

In a further aspect, the present invention provides a method of making 
available for downloading the above computer program. 

i 

In another aspect, the present invention provides an apparatus arranged to 
compensate for offset in a received signal, the signal being modified by a sequence of 
symbols, each symbol extending over 7^ signal samples, the apparatus comprising: a divider 
arranged to divide the received signal into frames of preferable length T s ; a divider arranged 
to divide each frame into a plurality of Nb sub-frames; and a processor arranged to form Nb 
sequences of values, the values being derived from the corresponding sub-frame within each 
frame; and to take said Nb sequences as successive estimates of a frame sequence correctly 
aligned (with no offset) to the sequence of symbols. 

For a better understanding of the invention, and to show how embodiments of 
the same may be carried into effect, reference will now be made, by way of example, to the 
accompanying diagrammatic drawings in which: 

Figure 1 is a diagram illustrating a watermark embedding apparatus; 

Figure 2 shows a signal portion extraction filter H; 
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Figures 3a and 3b show respectively the typical amplitude and phase responses 
as a function of frequency of the filter H shown in Fig. 2; 

Figure 4 shows the payload embedding and watermark conditioning stage of 

the apparatus shown in Fig. 1; 
5 Figure 5 is a diagram illustrating the details of the watermark conditioning 

apparatus He of Fig. 4, including charts of the associated signals at each stage; 

Figures 6a and 6b show two preferred alternative window shaping functions 
s(n) in the form of respectively a raised cosine function and a bi-phase function; 

Figures 7a and 7b show respectively the frequency spectra for a watermark 
"l0 sequence conditioned with a raised cosine and a bi-pnase snaping window runcuon; 

Figure 8 is a diagram illustrating a watermark detector in accordance with an 
embodiment of the present invention; 

Figure 9 diagrammatically shows the whitening filter H w of Fig. 8, for use in 
conjunction with a raised cosine shaping window function; 
1 5 Figure 1 0 diagrammatically shows the whitening filter H w of Fig. 8, for use in 

conjunction with a bi-phase window shaping function; 

Figure 1 1 shows details of the watermark symbol extraction and buffering 
processes in accordance with an embodiment of the present invention; 

Figure 12 shows a typical shape of the correlation function output from the 
20 correlator of the watermark detector shown in Fig. 8 ; and 

Figure 13 shows an example of one preferred implementation of the symbol 
extraction and buffering stage. 

Fig. 1 shows a block diagram of the apparatus required to perform the digital 
25 signal processing for embedding a multi-bit payload watermark w into a host signal x. 

A host signal x is provided at an input 12 of the apparatus. The host signal x is 
passed in the direction of output 14 via the adder 22. However, a replica of the host signal x 
(input 8) is split off in the direction of the multiplier 18, for carrying the watermark 
information. 

30 The watermark signal w c is obtained from the payload embedder and 

watermark conditioning apparatus 6, and derived from a reference finite length random 
sequence w s input to the payload embedder and watermark conditioning apparatus. The 
multiplier 18 is utilized to calculate the product of the watermark signal w c and the replica 
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audio signal x. The resulting product, w<x is then passed via a gain controller 24 to the adder 
22. The gain controller 24 is used to amplify or attenuate the signal by a gain factor a. 

The gain factor a controls the trade off between the audibility and the 
robustness of the watermark. It may be a constant, or variable in at least one of time, 
frequency and space. The apparatus in Fig. 1 shows that, when a is variable, it can be 
automatically adapted via a signal analyzing unit 26 based upon the properties of the host 
signal x. Preferably, the gain a is automatically adapted, so as to minimize the impact on the 
signal quality, according to a properly chosen perceptibility cost-function, such as a psycho- 
acoustic model of the human auditory system (HAS) in case of an audio signal. Such a model 
is, for instance, described in the paper by E.Zwicker, "Audio Engineering and 
Psychoacoustics: Matching signals to the final receiver, the Human Auditory System", 
Journal of the Audio Engineering Society, Vol. 39, pp. Vol.1 15-126, March 1991. 

In the following, an audio watermark is utilized, by way of example only, to 
describe this embodiment of the present invention. 

The resulting watermark audio signal y is then obtained at the output 14 of the 
embedding apparatus 10 by adding an appropriately scaled version of the product of w c and x 
to the host signal: 

y[ri] = x[n] + aw c [n]x{n] . (1) 

Preferably, the watermark w c is chosen such that when multiplied with x, it 
predominantly modifies the short time envelope of x. 

Fig. 2 shows one preferred embodiment in which the input 8 to the multiplier 
1 8 in Fig. 1 is obtained by filtering a replica of the host signal x using a filter H in the 
filtering unit 1 5. If the filter output is denoted by x b> then according to this preferred 
embodiment, the watermark signal is generated by adding the product of Xb and the 
watermark w c to the host signal x: 



Let x b be defined such that x b = x-x b , and yt be defined such that 
y = y b + x b , then the envelope modulated portion y b of the watermarked signal y is given as 



y[n] = x + ow c [n]x b [n]. 



(2) 



yb[n] = (l + w c [n])x b [n] 



(3) 
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Preferably, as shown in Fig. 3, the filter if is a linear phase band pass filter 
characterized by its lower cut-off frequency f L and upper cut-off frequency^. As can be seen 
in Fig. 3(b), the filter if has a linear phase response with respect to frequency /within the 
pass-band (BW). Thus, when if is a band pass filter, x b and x b are the in-band and out-of- 
5 band components of the host signal respectively. For optimum performance, it is preferable 
that the signals x b and x b are in phase. This is achieved by appropriately compensating for 
the phase distortion produced by filter K In the case of a linear phase filter, the distortion is a 
simple time delay. 

Tn Fi g. 4, the details of the pavload embedder and watermark conditioning unit 

10 6 is shown. In this unit, the initial reference random sequence w s is converted into a multi-bit j 

watermark signal w c > 

Firstly a finite length, preferably zero mean and uniformly distributed random 

sequence w s , from now on also referred to as the watermark seed signal, is generated using a 

random number generator with an initial seed S. As will be appreciated later, it is preferable 
1 5 that this initial seed S is known to both the embedder and the detector, such that a copy of the 

watermark signal can be generated at the detector for comparison purposes. This results in 

the sequence of length 

e [-U1 for k=0 9 l,2, L»rl (4) 

It should be noted that in some applications, the seed can be transmitted to the 
20 detector via an alternate channel or can be derived from the received signal using some pre- 
determined protocol. 

Then the sequence w $ is circularly shifted by the amounts d] and d 2 using the 
circularly shifting unit 30 to obtain the random sequences w dl and Wd2 respectively. It will be 
appreciated that these two sequences (wjj and Wdi) are effectively a first sequence and a 
25 second sequence, with the second sequence being circularly shifted with respect to the first. 
Each sequence w^, i == 1,2, is subsequently multiplied with a respective sign bit r h in the 
multiplying unit 40, where r* = +1 or -1 . The respective values of ri and r 2 remain constant, 
and only change when the payload of the watermark is changed. Each sequence is then ! 
converted into a periodic, slowly varying narrow-band signal w t of length LwT s by the j 
30 watermark conditioning circuit 20 shown in Fig. 4. Finally, the slowly varying narrow-band 1 
signals wj and w 2 are added with a relative delay T r (where T r <TJ to give the multi-bit | 

! 



I 
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payload watermark signal w c . This is achieved by first delaying the signal w 2 by the amount 
T r using delaying unit 45 and subsequently by adding it to wj with the adding unit 50. 

Fig. 5 shows the watermark conditioning apparatus 20 used in the payload 
embedder and watermark conditioning apparatus 6 in more detail. The watermark seed signal 
w s is input to the conditioning apparatus 20. 

For convenience, the modification of only one of the sequences w<# is shown 
in Fig. 5, but it will be appreciated that each of the sequences is modified in a similar manner, 
with the results being added to obtain the watermark signal w c . 

As shown in Fig. 5, each watermark signal sequence WdifkJ, i=l,2 is applied to 
the input of a sample repeater 180. Chart 181 illustrates one of the sequences as a 
sequence of values of random numbers between +1 and —1, with the sequence being of length 
In V . The sample repeater repeats each value within the watermark seed signal sequence T s 
times, so as to generate a rectangular pulse train signal. T s is referred to as the watermark 
symbol period and represents the span of the watermark symbol in the audio signal. Chart 
1 83 shows the results of the signal illustrated in chart 181 once it has passed through the 
sample repeater 180. 

A window shaping function sfnj 9 such as a raised cosine window, is then 
applied to convert the rectangular pulse functions derived from wjj and w& into slowly 
varying watermark sequence functions WjfnJ and w 2 [n] respectively. 

Chart 184 shows a typical raised cosine window shaping function, which is 
also of span T s . 

The generated watermark sequences wrfn] and w 2 [n] are then added up with a 
relative delay T r (where T r <T^ to give the multi-bit payload watermark signal w c [n] i.e., 

w*M «= WiM + w 2 [n -F r ] (5) 



The value of T r is chosen such that the zero crossings of wj match the 
maximum amplitude points of w 2 and vice-versa. Thus, for a raised cosine window shaping 
function T r =T/2, and for a bi-phase window shaping function T r =T/4. For other window 
shaping functions, other values of T r are possible. 

As will be appreciated by the below description, during detection the 
correlation oiw c [n] will generate two correlation peaks that are separated by pL ' (as can be 
seen in Fig. 12). pL ' is an estimate of the circular shift pL between w dl and W&, which is part 
of the payload, and is defined as 
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In addition to pL, extra information can be encoded by changing the relative 
signs of the embedded watermarks. 

In the detector, this is seen as a relative sign r sisn between the correlation 

5 peaks. It may be defined as: 

.a»- 2 -*y+ 3 «ftw} (7 > 

where p,=s\&L(cLi) and pf-&gz(cLj) are respectively estimates of the sign bits n (input 80) 
and r 2 (input 90) of Fig. 4, and cLj and cL 2 are the values of the correlation peak 
corresponding to w dl and respectively. The overall watermark payload^pA,, for an error- 
10 free detection, is then given as a combination of r<rign andpZ-: 

The maximum information (/„«„), in number of bits, that can be carried by a 
watermark sequence of length Ly, is thus given by: 

/- -1°8 2 ( 4 { VI) bits - (9) 

15 In such a scheme, the payload is immune to relative offset between the 

embedder and the detector, and also to possible time scale modifications. 

The window shaping function has been identified as one of the main 
parameters that controls the robustness and audibility behavior of the present watermarking 
scheme. As illustrated in Figs. 6a and b, two examples of possible window shaping functions 

20 are herein described - a raised cosine function and a bi-phase function. 

It is preferable to use a bi-phase window function instead of a raised cosine 
window function, so as to obtain a quasi DC-free watermark signal. This is illustrated in 
Figs. 7a and 7b, showing the frequency spectra corresponding to a watermark sequence (in 
this case a sequence of w<u[k] = {1,1,-1,1,-1,-1,}) conditioned with respectively a raised 

25 cosine and a bi-phase window shaping function. As can be seen, the frequency spectrum for 
the raised cosine conditioned watermark sequence has a maximum at frequency/ = 0, whilst 
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the frequency spectrum for the bi-phase shaped watermark sequence has a minimum at/= 0 
i.e. it has very little DC component. 

Useful information is only contained in the non-£>C component of the 
watermark. Consequently, for the same added watermark energy, a watermark conditioned 
5 with the bi-phase window will carry more useful information than one conditioned by the 
raised cosine window. As a result, the bi-phase window offers superior audibility 
performance for the same robustness or, conversely, it allows a better robustness for the same 
audibility quality. 

Such a bi-phase function could be utilized as a window shaping function for 
10 other watermarking schemes. In other words, a bi-phase function could be applied to reduce 
the DC component of signals (such as a watermark) that are to be incorporated into another 
signal. 

Fig. 8 shows a block diagram of a watermark detector (200, 300, 400). The 
detector consists of three major stages: (a) the watermark symbol extraction stage (200), (b) 

15 the buffering and interpolation stage (300), and (c) the correlation and decision stage (400). 

In the symbol extraction stage (200), the received watermarked signal y '[n] is 
processed to generate multiple (i\fr) estimates of the watermarked sequence. These estimates 
of the watermark sequence are required to resolve time offset that may exist between the 
embedder and the detector, so that the watermark detector can synchronize to the watermark 

20 sequence inserted in the host signal. 

In the buffering and interpolation stage (300), these estimates are de- 
multiplexed into Ni> separate buffers, and an interpolation is applied to each buffer to resolve 
time scale modifications that may have occurred, e.g. a drift in sampling (clock) frequency 
may have resulted in a stretch or shrink in the time domain signal (i.e. the watermark may 

25 have been stretched or shrunk). 

In the correlation and decision stage (400), the content of each buffer is 
correlated with the reference watermark and the maximum correlation peaks are compared 
against a threshold to determine the likelihood of whether the watermark is indeed embedded 
within the received signal y'[n]. 

30 In order to maximize the accuracy of the watermark detection, the watermark 

detection process is typically carried out over a length of received signal y'fnj that is 3 to 4 
times that of the watermark sequence length. Thus each watermark symbol to be detected can 
be constructed by taking the average of several estimates of said symbol. This averaging 
process is referred to as smoothing, and the number of times the averaging is done is referred 
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to as the smoothing factor s/. Let Lo be the detection window length, defined as the length of 
the audio segment (in number of samples) over which a watermark detection truth-value is 
reported. Then, L D =sjLy 9 T s> where T s is the symbol period and L, 9 the number of symbols 
within the watermark sequence. During symbol extraction, a factor T s decimation takes place 
5 in the energy computation stage. Thus, the length (L0 of each buffer 320 within the buffering 
and interpolation stage is Lt=s/L w . 

In the watermark symbol extraction stage 200 shown in Fig. 8, the incoming 
watermark signal y '[n] is input to the optional signal conditioning filter H b (210). This filter 
210 is typically a band pass filter and has the same behavior as the corresponding filter (H, 

To IS) shown in Fig. 2. The output of the inter tt b is y tlnj ana, assuming linearity witnin the 

transmission medium, it follows from equations (1) and (3): 

y\ M * y* W = (i +«hC»])x & [«] (io) 

Note that in the above expression, the possible time offset between the 
15 embedder and the detector is implicitly ignored. For ease of explanation of the general 
watermarking scheme principles, from now on, it is assumed that there is perfect 
synchronism between the embedder and the detector (i.e. no offset). Explanation is given 
however below in reference to Fig. 1 1 of how to compensate for time offset in accordance 
with the present invention. 
20 Note that when no filter is used in the embedder (i.e., when H=l) then H b in 

the detector can also be omitted, or it can still be included to improve the detection 
performance. If H b is omitted, then y b in equation (10) is replaced with y. The rest of the 
processing is the same. 

We assume that the audio signal is divided into frames of length T S9 and that 
25 y ' b ,tn[n] is the n-th sample of the m-th filtered frame signal. The energy E[m] corresponding 
to the w-th frame is: 



n=0 



30 
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Combining this with equation 10, it follows that: 



T -1 T —1 

iM«i;K>j| 2 =L|a+c^ e [m]K m [«]| 

n=0 



T M -l 

§l 

/j=0 



(12) 



where w e [m] is the m-fft extracted watermark symbol and contains Nb time-multiplexed 
estimates of the embedded watermark sequences. Solving ioxw e [m] in equation 12 and 
ignoring higher order terms of a, gives the following approximation: 



la 







2 






2 



•1 



(13) 



In the watermark extraction stage 200 shown in Fig. 8, the output y 3 b[n] of the 
filter H b is provided as an input to a frame divider 220, which divides the audio signal into 

1 0 frames of length 7^ i.e. into y 'b im [n], with the energy calculating unit 23 0 then being used to 
calculate the energy corresponding to each of the framed signals as per equation (12). The 
output of this energy calculation unit 230 is then provided as an input to the whitening stage 
H w (240) which performs the function shown in equation 13 so as to provide an output w e [mj. 
Alternative implementations (240A, 240B) of this whitening stage are illustrated in Figs. 9 

15 and 10. 

It will be realized that the denominator of equation 1 3 contains a term that 
requires knowledge of the host (original) signal x. As the signal x is not available to the 
detector, it means that in order to calculate w e [m] then the denominator of equation 13 must 
be estimated. 

20 Below is described how such an estimation can be achieved for the two 

described window shaping functions (the raised cosine window shaping function and the bi- 
phase window shaping), but it will equally be appreciated that the teaching could be extended 
to other window shaping functions. 

In relation to the raised cosine window shaping function shown in Fig. 6a, it 

25 has been realized that the audio envelope induced by the watermark contributes only to the 
noisy part of the energy function EfmJ. The slowly varying part (i.e. the low frequency 
components) is predominately due to the contribution of the envelope of the original audio 
signal x. Thus, equation 13 may be approximated by: 
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1 ( Ejm] 



2a I lowpass(jEXm]) 



(14) 



where "lowpass(.)" is a low pass filter function. Thus, it will be appreciated that the 
whitening filter H w for the raised cosine window shape in the function can be realized as 
shown in Fig. 9. 

5 ~ - As can be seen, such a whitening filter H yv (240A) comprises an input 242A 

for receiving the signal EfmJ. A portion of this signal is then passed through the low pass 
filter 947 A to produce a Tow pass filtered energ y si gnal Er P rmh which m turn is provided as 
an input to the calculation stage 248A along with the function EfmJ. The calculation stage 
248 A then divides EfmJ by EwfmJ to calculate the extracted watermark symbol w e [m]. 

1 o When a bi-phase window function is employed in the watermark conditioning 

stage of the embedder, a different approach should be utilized to estimate the envelope of the 
original audio, and hence to calculate w e [m]. 

It will be seen by examination of the bi-phase window function shown in Fig. 
6b, that when the audio envelope is modulated with such a window function, the first and the 

15 second halves of the frame are scaled in opposite directions. In the detector, this property is 
utilized to estimate the envelope energy of the host signal x. 

Consequently, within the detector, each audio frame is first sub-divided into 
two halves. The energy functions corresponding to the first and second half-frames are hence 
given by 

ESmW'j?\y\^[nf (15) 

n=0 

20 and 

n=T t /2 



respectively. As the envelope of the original audio is modulated in opposite directions within 
the two sub-frames, the original audio envelope can be approximated as the mean of EifmJ 
and E2[mJ. 

25 Further, the instantaneous modulation value can be taken as the difference 

between these two functions. Thus, for the bi-phase window function, the watermark w e fmj 
can be approximated by: 
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r 1 1 ( E l [m]-E 2 [m] 
el J 2a{E,[m]+E 2 [m'] J 



(17) 



Consequently, the whitening filter H w (240B) in Fig. 8 for a bi-phase window 
shaping function can be realized as shown in Fig. 10. Inputs 242B and 243B respectively 
5 receive the energy functions of the first and second half frames EjfmJ and E 2 [m]. Each 
energy function is then split up into two, and provided to adders 245B and 246B which 
respectively calculate EjfmJ - E 2 [m] y and EjfmJ + E 2 [mJ. Both of these calculated functions 
are then passed to the calculating unit 24B which divides the value from adder 245B by the 
value from 246B so as to calculate w e [m] f containing N b time-multiplexed estimates of the 

10 embedded watermark sequences, in accordance with equation 17. 

This output WefmJ is then passed to the buffering and interpolation stage 300, 
where the signal is de-multiplexed by a de-multiplexer 310, buffered in buffers 320 of length 
Lb 7 so as to resolve a lack of synchronism between the embedder and the detector, and 
interpolated within the interpolation unit 330 so as to compensate for a time scale 

1 5 modification between the embedder and the detector. 

In order to maximize the possible robustness of a watermark, it is important to 
make sure that the watermarking system is immune to time offsets between the embedder arid 
the detector. In other words, the watermark detector must be able to synchronize to the 
watermark sequence inserted in the host signal. 

20 Fig. 1 1 illustrates the process carried out by the buffering and interpolation 

stage 300 to resolve the offset issue. The example described illustrates the process for 
resolving offset when a raised cosine window shaping function has been employed in the 
watermark embedding process. However, in principle the same technique is applicable when 
the bi-phase window shaping function has been used. 

25 Referring to Fig. 1 1, after filtering by the filter H b 210, the incoming audio 

signal streamy *b[n] is separated into preferably overlapping frames 302 of effective length T s 
by the frame divider 220. 

Preferably, to resolve possible offset between the embedder and the detector, 
each frame is divided into Nb sub-frames (304a, 304b,. . .,304x), and the above computations 

30 (equations (12) to (17)) are applied on a sub-frame basis. 



PHNL020242EPP 




14 26.03.2002 
Preferably, each sub-frame overlaps with an adjacent sub-frame. In the 
example shown, it can be seen that there is a 50% overlap (T/N b ) of each sub-frame (304a, 
304b, 304x), with each of the sub-frames being of length 2TM. When overlapping sub- 
frames are considered, the main frames are preferably longer than the symbol period T 3 so as 
5 to allow inter-frame overlap as shown in Fig. 1 1 . 

The energy of the audio is then computed for each sub-frame by the whitening 
stage 240, and the resulting values are de-multiplexed into the N b buffers 320 by the de- 
multiplexer 310. Each successive one(5/, B* B Nb ) of the buffers 320 will thus contain a 
sequence of values, with the first buffer Bi contai n i n g a sequence of values corresponding to 
10 the first sub-frame within each frame, the second buffer B 2 containing a sequence ot values 
corresponding to the second sub-frame within each frame etc. 

If wdi is the content of the i-th buffer, then it can be shown that: 

w Dl [k] = yv e [k-N b +i\ke {0 4 -1} OS) 



1 5 where Lb is the buffer length. 

For a raised cosine window shaping function, the energy of the embedded 
watermark is concentrated near the center of the frame, such that the sub-frame best aligned 
with the center of the frame will result in a distinctly better estimate of the embedded 
watermark symbol than all the other sub-frames. Effectively, each buffer thus contains an 

20 estimate of the symbol sequence, the estimates corresponding to the sequences having 

different time offsets. 

The sub-frame best aligned with the center of the frame (i.e. the best estimate 

of the correctly aligned frame) is determined by correlating the contents of each buffer with 

the reference watermark sequence. The sequence with the maximum correlation peak value is 
25 chosen as the best estimate of the correctly aligned frame. The corresponding confidence 

level, as described below, is used to determine the truth-value of the detection. Preferably, the 

correlation process is halted once an estimated watermark sequence with a correlation peak 

above the defined threshold has been found. 

Typically, the length of each buffer is between 3 to 4 times the watermark 
30 sequence length L„, and is thus typically of length between 2048 and 8192 symbols, and N b is 

typically within the range of 2 to 8. 
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The buffer is normally 3 to 4 times that of the watermark sequence so that 
each watermark symbol can be constructed by taking the averages of several estimates of said 
symbol. This averaging process is referred to as smoothing, and the number of times the 
averaging is done is referred to as the smoothing factor s/. Thus, given the buffer length Lb 
and the watermark sequence length the smoothing factor Sf is such that: 

Lb^s/K (19) 



In another preferred embodiment, the detector refines the parameters used in 
the offset search based upon the results of a previous search step. For instance, if a first series 
of estimates shows that the results stored in buffer B$ provide the best estimate of the 
information signal, then the next offset search (either on the same received signal, or on the 
signal received during the next detection window) is refined by shifting the position of the 
sub-frames towards the position of the best estimate sub-frame. The estimates of the 
sequence having zero offset can thus be iteratively improved. 

As shown in Fig. 8, outputs (woi, Wdz ... >f£>W from the buffering stage are 
passed to the interpolation stage and, after interpolation, the outputs (wju ... >t>W of this 
stage, which are needed to resolve a possible time scale modification in the watermarked 
signal, are passed to the correlation and decision stage. All of the estimates (wjj, w/z-. wnik) 
of the watermark corresponding to the different possible offset values are passed to the 
correlation and decision stage 400. 

The correlator 410 calculates the correlation of each estimate Wjj, j—1, ...,JV$ 
with respect to the reference watermark sequence w c [k]. Each respective correlation output 
corresponding to each estimate is then applied to the maximum detection unit 420 which 
determines which two estimates provided the maximum correlation peak values. These 
estimates are chosen as the ones that best fit the circularly shifted versions w<u and of the 
reference watermark. The correlation values for these estimated sequences are passed to the 
threshold detector and payload extractor unit 430. 

The reference watermark sequence w s used within the detector corresponds to 
(a possibly circularly shifted version of) the original watermark sequence applied to the host 
signal. For instance, if the watermark signal was calculated using a random number generator 
with seed S within the embedder, then equally the detector can calculate the same random 
number sequence using the same random number generation algorithm and the same initial 
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seed S so as to determine the watermark signal. Alternatively, the watermark signal originally 
applied in the embedder and utilized by the detector as a reference could simply be any 

predetermined sequence. 

Fig. 12 shows a typical shape of a correlation function as output from the 
5 correlator 41 0. The horizontal scale shows the correlation delay (in terms of the sequence 
samples). The vertical scale on the left hand side (referred to as the confidence level cL) 
represents the value of the correlation peak normalized with respect to the standard deviation 
of the normally distributed correlation function. 

As can be seen, the typical correlation is relatively flat with respect to ci, and 

-Jq centered about cL = 0. However, the function contains two peaks, wnicn are separated by pL 

(see equation 6) and extend upwards to cL values that are above the detection threshold when 
a watermark is present. When the correlation peaks are negative, the above statement applies 

to their absolute values. 

A horizontal line (shown in the Fig. as being set at cL » 8.7) represents the 

1 5 detection threshold. The detection threshold value controls the false alarm rate. 

Two kinds of false alarms exist: The false positive rate, defined as the 
probability of detecting a watermark in non watermarked items, and the false negative rate, 
which is defined as the probability of not detecting a watermark in watermarked items. 
Generally, the requirement of the false positive alarm is more stringent than that of the false 

20 negative. The scale on the right hand side of Fig. 1 1 illustrates the probability of a false 
positive alarm b. As can be seen in the example shown, the probability of a false positive 
b=J0' 12 is equivalent to the threshold cL = 8.7, whilst b = Iff 63 is equivalent to cL = 20. 

After each detection interval, the detector determines whether the original 
watermark is present or whether it is not present, and on this basis outputs a "yes" or a "no" 

25 decision. If desired, to improve this decision making process, a number of detection windows 
may be considered. In such an instance, the false positive probability is a combination of the 
individual probabilities for each detection window considered, dependent upon the desired 
criteria. For instance, it could be determined that if the correlation function has two peaks 
above a threshold of cL = 7 on any two out of three detection intervals, then the watermark is 

30 deemed to be present Such detection criteria can be altered depending upon the desired use 
of the watermark signal and to take into account factors such as the original quality of the 
host signal and how badly the signal is likely to be corrupted during normal transmission. 

The payload extractor unit 430 may subsequently be utilized to extract the 
payload (e.g. information content) from the detected watermark signal. Once the unit has 
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estimated the two correlation peaks cLi and cLa that exceed the detection threshold, an 
estimate cl/ of the circular shift cL (defined in equation (6)) is derived as the distance 
between the peaks . Next, the signs pi and & of the correlation peaks are determined, and 
hence r si gn calculated from equation (7). The overall watermark payload may then be 
5 calculated using equation (8). 

For instance, it can be seen in Fig. 12 that pL is the relative distance between 
the two peaks. Both peaks are positive i.e. pi = +1, and p2 = +1. From equation (7), r S ign = 3. 
Consequently, the payload pLw = <3, pL>- 

The symbol extraction and buffering stages described in Figs. 8 can be 
10 efficiently implemented by the apparatus 500 shown in Fig. 13. Here, the offset 

compensation is achieved without any extra computation. It will also be seen that the de- 
multiplexing is achieved with a simple set of delays and decimation blocks. 

First, the incoming frame signal y b>m is subdivided into N b non-overlapping 
sub-frames of length TVNb and the energy of each sub-frame is computed using the energy 
15 computation unit 230. Secondly, the whitening filter H w is applied in the whitening unit 240. 
The combination of the delay unit 510 and the adding unit 520 effectively realizes a 50% 
overlap between adjacent sub-frames. After the watermark symbol sequence w e [m] is 
generated at the output of the adder unit 520, it is subsequently distributed over the Nb buffer 
unit 320 using the combination of the delay set 512 and the down sampling set 530. This is 
20 done such that each buffer gets one value for every Nb in coming samples of w e [k]. For 

instance, if the first sample goes to Wpi, the second sample goes to wd2, third one to Wd3> •> 
the Nb-th one to w D Nb and then the (Nb+l)-th one goes back to w D i and so on until all the 
buffers are filled up. Thus the i-th buffer entry w Di [k] may be expressed as 

w Di [k-\ = WelN b k + i\, (20) 

25 It is seen that the sampling frequency of Woi[k] is 1/Nb times that of w e [mj. 

This decimation is achieved via the decimating set 532 in Fig. 13. 

Since non-overlapping frames are considered in the energy computing unit 
230, the total computation needed to generate the Nb sequences is the same as that would 
have been required if only one sequence with symbols extending over the whole frame was 

30 computed. 

It will be appreciated by the skilled person that various implementations not 
specifically described would be understood as falling within the scope of the present 
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invention. For instance, whilst only the functionality of the detecting apparatus has been 
described, it will be appreciated that the apparatus could be realized as a digital circuit, an 
analog circuit, a computer program, or a combination thereof. 

Equally, whilst the above embodiment has been described with reference to an 
5 audio signal, it will be appreciated that the present invention can be applied to add 

information to other types of signal, for instance information or multimedia signals, such as 
video and data signals. : 

Further, it will be appreciated that the invention can be applied to 
watermarking schemes containing only one watermarking sequence (i.e. a 1-bit scheme), or 
10 to watermarking schemes containing multiple watermarking sequences. Such multiple 
sequences can be simultaneously or successively embedded within the host signal. 

Equally, whilst the above detection of the watermark has been described with 
each estimate being correlated, it will be appreciated that the correlation procedure can be 
arranged to stop once a positive detection of the watermark has been made. This reduces the 
1 5 offset determination time. Further, the decoder can be arranged to adaptively compensate for 
time offset, by re-ordering the buffers (or the order in which the buffers are correlated) such 
that the best aligned buffer in the current detection window will be the first buffer to be 
correlated in the next detection window. 

Within the specification it will be appreciated that the word "comprising" does 
20 not exclude other elements or steps, that "a" or "and" does not exclude a plurality, and that a 
single processor or other unit may fulfil the functions of several means recited in the claims. 
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1 . A method of compensating for offset in a received signal, the signal being 
modified by a sequence of symbols, each symbol extending over 7^ signal samples, the 
method comprising the steps of: j - 

(a) dividing the received signal into frames ; 

5 (b) dividing each frame into a plurality of Nb sub-frames; 

(c) forming Nb sequences of values, the values being derived from the 
corresponding sub-frame within each frame; and 

(d) taking said Nb sequences as successive estimates of a frame sequence correctly 
aligned (to the sequence of symbols. 

10 

2. A method as claimed in claim 1, wherein each frame is of predetermined 
length Ts. 

3. A method as claimed in claim 1, wherein there is an inter-frame overlap, 

15 

4. A method as claimed in claim 1, wherein each sub-frame overlaps an adjacent 
sub-frame. 

5. A method as claimed in claim 1 , wherein Nb lies within the range 2 to 8. 

20 

6. A method as claimed in claim 1 , wherein the sequence of symbols comprises 
Lyf symbols, the received signal being divided into Lf frames, wherein Lf is an integral 
multiple of L^. 
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CLAIMS: 



25 



7. A method as claimed in claim 1, wherein said sequence of symbols comprises 

a sequence of values convolved with a window shaping function that has a band limited 
frequency behavior and a smooth temporal behavior. 
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8. A method as claimed in claim 7, wherein said window shaping function has a 
symmetric or an anti-symmetric temporal behavior. 

9. A method as claimed in claim 1, wherein said sequence of symbols comprises 
5 a sequence of at least one of raised cosine functions or bi-phase functions. 

1 o. A method as claimed in claim 1 , wherein said offset is a time offset 

11. A method as claimed in claim 1 , the method further comprising processing 
10 each estimate as though it were the correctly aligned frame sequence, so as to determine 

which estimate is the best estimate. 

12. A method as claimed in claim 1 1 , wherein the best estimate is assumed to be 
the first estimate that, when processed, exceeds one or more predetermined conditions; said 

15 processing of estimates stopping once the best estimate has been determined. 

13. A method as claimed in claim 1 , the method further comprising the step of 
correlating each of said estimates with a reference corresponding to said sequence of 
symbols; and 

20 taking the estimate with the maximum correlation peak value as the best estimate. 

14. A method as claimed in any one of claims 11, 12 or 13, wherein once a first 
best estimate has been determined for a first signal or portion of a signal, the method is 
repeated for a further received signal or portion of a signal, the estimates from said further 

25 signal being processed in an order dependent upon said first best estimate. 

15. A computer program arranged to perform the method as claimed in claim 1 . 

16. A record carrier comprising a computer program as claimed in claim 1 5 . 

30 

17. A method of making available for downloading a computer program as 
claimed in claim 15. 
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18. An apparatus arranged to compensate for offset in a received signal, the signal 

being modified by a sequence of symbols, each symbol extending over T s signal samples, the 
apparatus comprising: 

a divider arranged to divide the received signal into frames; 
5 a divider arranged to divide each frame into a plurality of Nb sub-frames; and 

a processor arranged to form Nb sequences of values, the values being derived 
from the corresponding sub-frame within each frame; and to take said Nb sequences as 
successive estimates of a frame sequence correctly aligned with the sequence of symbols. 

10 19. An apparatus as claimed in claim 1 8, the apparatus further comprising a buffer 

arranged to store said Nb sequences. 



20. 



A decoder comprising the apparatus as claimed in claim 18. 
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@ 

Method and apparatus are described for compensating for time offset in a 
received signal, so as to correctly align the frame sequence of a received signal to a sequence 
of transmitted symbols. Each symbol extends over T s signal samples. The received signal is 
first divided into a sequence of frames of length 2^, and then each frame divided into a 
multiplicity of sub-frames. Subsequently, Nb sequences of values are formed, where every 
successive value in each sequence is derived from the corresponding sub-frame within each 
successive frame. Each of the N b sequences is an estimate for the correctly aligned sequence 
of transmitted symbols. 
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